std::literals::chrono_literals:: operator""s
|
Défini dans l'en-tête
<chrono>
|
||
|
constexpr
std::
chrono
::
seconds
operator "" s ( unsigned long long secs ) ; |
(1) | (depuis C++14) |
|
constexpr
std::
chrono
::
duration
<
/*unspecified*/
>
operator "" s ( long double secs ) ; |
(2) | (depuis C++14) |
Forme un littéral std::chrono::duration représentant des secondes.
Table des matières |
Paramètres
| secs | - | le nombre de secondes |
Valeur de retour
Le littéral std::chrono::duration .
Implémentation possible
constexpr std::chrono::seconds operator""s(unsigned long long s) { return std::chrono::seconds(s); } constexpr std::chrono::duration<long double> operator""s(long double s) { return std::chrono::duration<long double>(s); } |
Notes
Cet opérateur est déclaré dans l'espace de noms std :: literals :: chrono_literals , où à la fois literals et chrono_literals sont des espaces de noms inline . L'accès à cet opérateur peut être obtenu avec :
- using namespace std :: literals ,
- using namespace std :: chrono_literals , ou
- using namespace std :: literals :: chrono_literals .
De plus, dans l'espace de noms std :: chrono , la directive using namespace literals :: chrono_literals ; est fournie par la bibliothèque standard , de sorte que si un programmeur utilise using namespace std :: chrono ; pour accéder aux classes de la bibliothèque chrono , les opérateurs littéraux correspondants deviennent également visibles.
std::string
définit également
operator
""
s
, pour représenter les objets littéraux de type
std::string
, mais il s'agit d'un littéral de chaîne :
10s
représente dix secondes, tandis que
"10"
s
est une chaîne de deux caractères.
Exemple
#include <chrono> #include <iostream> int main() { using namespace std::chrono_literals; std::chrono::seconds halfmin = 30s; std::cout << "Half a minute is " << halfmin.count() << " seconds" " (" << halfmin << ").\n" "A minute and a second is " << (1min + 1s).count() << " seconds.\n"; std::chrono::duration moment = 0.1s; std::cout << "A moment is " << moment.count() << " seconds" " (" << moment << ").\n" "And thrice as much is " << (moment + 0.2s).count() << " seconds.\n"; }
Sortie :
Half a minute is 30 seconds (30s). A minute and a second is 61 seconds. A moment is 0.1 seconds (0.1s). And thrice as much is 0.3 seconds.
Voir aussi
|
construit une nouvelle durée
(fonction membre publique de
std::chrono::duration<Rep,Period>
)
|